Add npm publish GitHub workflow for tag pushes #26
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This PR adds a new GitHub workflow that automatically publishes the package to npm when a tag is pushed to the repository.
Changes Made
.github/workflows/publish.ymlworkflow file that:NPM_TOKENrepository secretcheckout@v4,setup-node@v4)Workflow Details
The publish workflow follows these steps:
actions/checkout@v4actions/setup-node@v4with npm registry configurationnpm install(including puppeteer for browser tests)npm run lintnpm run buildnpm testnpm run test:browsernpm publishwithNPM_TOKENauthenticationThe workflow ensures that all quality checks pass before publishing, maintaining the same CI standards as the existing
nodejs.ymlworkflow.Usage
Once the
NPM_TOKENrepository secret is configured, the workflow will automatically publish to npm whenever a tag is pushed:Fixes #25.
Warning
Firewall rules blocked me from connecting to one or more addresses
I tried to connect to the following addresses, but was blocked by firewall rules:
googlechromelabs.github.ionode install.mjs(dns block)https://storage.googleapis.com/chrome-for-testing-public/134.0.6998.35/linux64/chrome-headless-shell-linux64.zipnode install.mjs(http block)https://storage.googleapis.com/chrome-for-testing-public/134.0.6998.35/linux64/chrome-linux64.zipnode install.mjs(http block)If you need me to access, download, or install something from one of these locations, you can either:
💡 You can make Copilot smarter by setting up custom instructions, customizing its development environment and configuring Model Context Protocol (MCP) servers. Learn more Copilot coding agent tips in the docs.